package com.ruoyi.system.mapper;

import java.util.Date;
import java.util.List;
import java.util.Map;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.ruoyi.system.domain.TSpProjectDetail;
import org.apache.ibatis.annotations.Param;
import org.springframework.security.core.parameters.P;

/**
 * 项目收入支出流水Mapper接口
 * 
 * @author ruoyi
 * @date 2024-03-21
 */
public interface TSpProjectDetailMapper  extends BaseMapper<TSpProjectDetail>
{
    /**
     * 查询项目收入支出流水
     * 
     * @param pdetailId 项目收入支出流水主键
     * @return 项目收入支出流水
     */
    public TSpProjectDetail selectTSpProjectDetailByPdetailId(String pdetailId);

    /**
     * 查询项目收入支出流水列表
     * 
     * @param tSpProjectDetail 项目收入支出流水
     * @return 项目收入支出流水集合
     */
    public List<TSpProjectDetail> selectTSpProjectDetailList(TSpProjectDetail tSpProjectDetail);

    /**
     * 新增项目收入支出流水
     * 
     * @param tSpProjectDetail 项目收入支出流水
     * @return 结果
     */
    public int insertTSpProjectDetail(TSpProjectDetail tSpProjectDetail);

    /**
     * 修改项目收入支出流水
     * 
     * @param tSpProjectDetail 项目收入支出流水
     * @return 结果
     */
    public int updateTSpProjectDetail(TSpProjectDetail tSpProjectDetail);


    /**
     * 批量修改
     *
     * @param tSpProjectDetail 项目收入支出流水
     * @return 结果
     */
    public int bacthUpdateTSpProjectDetail(List<TSpProjectDetail> list);

    /**
     * 删除项目收入支出流水
     * 
     * @param pdetailId 项目收入支出流水主键
     * @return 结果
     */
    public int deleteTSpProjectDetailByPdetailId(String pdetailId);

    /**
     * 批量删除项目收入支出流水
     * 
     * @param pdetailIds 需要删除的数据主键集合
     * @return 结果
     */
    public int deleteTSpProjectDetailByPdetailIds(String[] pdetailIds);


    /**
     * 查询项目收入支出统计   按项目Id，月份，费用类别
     *
     * @param projectId 项目ID
     * @param month
     * @return 项目收入支出流水
     */
    public Map<String,Object> selectProjectDetailBycostId(@Param("projectId") String projectId,
                                                                @Param("month") String month,
                                                                @Param("costId") String costId);


    /**
     * 查询项目收入支出统计   按项目查询上个月数据
     *
     * @param projectId 项目ID
     * @param month
     * @return 项目收入支出流水
     */
    public List<Map<String,Object>> selectProjectDetailByLastMonth(@Param("projectId") String projectId,@Param("month") String month);


    /**
     * 查询 固定时间 最近的一条数据
     *
     * @return 项目收入支出流水
     */
    public TSpProjectDetail selectByRecently(@Param("bankId") Long bankId,
                                             @Param("costDate") Date costDate);

    /**
     * 查询 固定时间 最近的一条数据  修改使用
     *
     * @return 项目收入支出流水
     */
    public TSpProjectDetail selectByRecentlyUpd(@Param("bankId") Long bankId,
                                                @Param("pdetailId") String pdetailId,
                                                @Param("costDate") Date costDate);


    /**
     * 查询 固定时间 之后的全部数据
     *
     * @return 项目收入支出流水
     */
    public List<TSpProjectDetail> selectByAfterList(@Param("bankId") Long bankId,
                                                    @Param("costDate") Date costDate,
                                                    @Param("pdetailId") String pdetailId);
}
